

#### **COM-ORG**

## W2: Project-2 Overview

31110321 Computer Organization สำหรับนักศึกษาชั้นปีที่ 3 สาขาวิชาวิศวกรรมคอมพิวเตอร์

> ทรงฤทธิ์ กิติศรีวรพันธุ์ songrit@npu.ac.th สาขาวิชาวิศวกรรมคอมพิวเตอร์ มหาวิทยาลัยนครพนม

# Project 1 (สัปดาห์ก่อน)

Given : Nand

Elementary logic gates

- Not
- And
- o Or
- Xor
- Mux
- DMux

<u>16-bit</u>

variants

- □ Not16
- And16
- o 0r16
- Mux16

Multi-way

variants

- Or8Way
- Mux4Way16
- Mux8Way16
- DMux4Way
- DMux8Way

### **Outline**

- Chipset : ใช้ชิปจาก Project-1
- Goal : สร้างชิปเซตต่อไปนี้
  - □ HalfAdder
  - □ FullAdder
  - □ Add16
  - □ Inc16
  - ALU

ใช้ชิปเซตจาก Project-1 ประกอบเป็นชิปเซต ใหม่

### Half Adder



| а | b | sum | carry |
|---|---|-----|-------|
| 0 | 0 | 0   | 0     |
| 0 | 1 | 1   | 0     |
| 1 | 0 | 1   | 0     |
| 1 | 1 | 0   | 1     |

#### HalfAdder.hdl

```
/** Computes the sum of two bits. */
CHIP HalfAdder {
    IN a, b;
    OUT sum, carry;
    PARTS:
    // Put your code here:
}
```

#### • คำแนะนำ

• สามารถ<u>ใช้ลอจิกเกตพื้นฐาน</u> สร้าง Half Adder ได้

### Full Adder



#### FullAdder.hdl

```
/** Computes the sum of three bits. */
CHIP HalfAdder {
    IN a, b, c;
    OUT sum, carry;
    PARTS:
    // Put your code here:
}
```

| а | b | С | sum | carry |
|---|---|---|-----|-------|
| 0 | 0 | 0 | 0   | 0     |
| 0 | 0 | 1 | 1   | 0     |
| 0 | 1 | 0 | 1   | 0     |
| 0 | 1 | 1 | 0   | 1     |
| 1 | 0 | 0 | 1   | 0     |
| 1 | 0 | 1 | 0   | 1     |
| 1 | 1 | 0 | 0   | 1     |
| 1 | 1 | 1 | 1   | 1     |

#### • คำแนะนำ

- สามารถใช้ 2 Half Adder
- สร้าง Full adder

### 16-bit adder



#### Add16.hdl

```
/*
 * Adds two 16-bit, two's-complement values.
 * The most-significant carry bit is ignored.
 */

CHIP Add16 {
    IN a[16], b[16];
    OUT out[16];

    PARTS:
    // Put you code here:
}
```

#### • คำแนะนำ

- ∘ ใช้ n-bit adder ใช้สร้าง n-bit full-adder
  - Carry bit เป็นลำดับต่อเนื่องจาก ผลชอง carry bit จากบิตขวาไปบิต ซ้าย
  - ไม่สนใจ MSB carry bit

### 16-bit incrementor



#### • คำแนะนำ

- ∘ ผลลัพธ์ out=in+1<sub>b</sub>
- พิจารณาระบบ Inc2 (2บิท)
- มีกรณีรับ carry จากบิตทางขวา
- มีกรณีส่งต่อ carry บิทไปบิท ทางซ้าย

```
/*
 * Outputs in + 1.
 * The most-significant carry bit is ignored.
 */

CHIP Inc16 {
    IN in[16];
    OUT out[16];

PARTS:
    // Put you code here:
}
```

# Chipset (composite)

Mux16, Not16, And16, Or8Way



# Not16, And16, Or8Way

```
Chip name: Not16
```

**Inputs:** in[16] // a 16-bit pin

Outputs: out[16]

Function: For i=0..15 out[i]=Not(in[i]).

Not16 -> flip-bit

Chip name: And16

Inputs: a[16], b[16]

Outputs: out[16]

Function: For i=0..15 out[i]=And(a[i],b[i]).

And16 คู่บิท

Chip name: Or8Way

Inputs: in[8]

Outputs: out

**Function:** out=Or(in[0],in[1],...,in[7]).

out=0 กรณีเดียว

### ALU



#### • คำแนะนำ

- สร้าง blocks : Add16 และใช้ ลอจิกเกตจาก Project-1
- สามารถสร้าง ALU ได้โดยใช้ HDL code ประมาณ 20 บรรทัด
- ใช้ทุกชิปเซตที่ทำมาช่วยให้โค้ดสั้น

#### ALU.hdl

## ALU components: zx, zy

•ใช้ Mux สำหรับ zx



•ใช้ Mux สำหรับ zy



# **ALU components: nx**

Negative X





# **ALU components: nx**

•ใช้ Mux สำหรับ zx, nx



| zx | nx | out    |
|----|----|--------|
| 0  | 0  | X      |
| 0  | 1  | !x     |
| 1  | 0  | 0x0000 |
| 1  | 1  | 0x1111 |

# ALU components: zy, ny

#### •เช่นเดียวกับ zx, nx



| zy | ny | out_y  |
|----|----|--------|
| 0  | 0  | у      |
| 0  | 1  | !у     |
| 1  | 0  | 0x0000 |
| 1  | 1  | 0x1111 |

# ALU: x+y K5p x & y



# ALU: x+y, x &y ua: no



# **ALU diagram**



### Hack ALU output control bits



- if (out == 0) then zr = 1, • else zr = 0
- if (out < 0) then ng = 1,</li>else ng = 0

| zx | nx | zy | ny | f | no | out |
|----|----|----|----|---|----|-----|
| 1  | 0  | 1  | 0  | 1 | 0  | 0   |
| 1  | 1  | 1  | 1  | 1 | 1  | 1   |
| 1  | 1  | 1  | 0  | 1 | 0  | -1  |
| 0  | 0  | 1  | 1  | 0 | 0  | Х   |
| 1  | 1  | 0  | 0  | 0 | 0  | у   |
| 0  | 0  | 1  | 1  | 0 | 1  | !x  |
| 1  | 1  | 0  | 0  | 0 | 1  | !y  |
| 0  | 0  | 1  | 1  | 1 | 1  | -x  |
| 1  | 1  | 0  | 0  | 1 | 1  | -у  |
| 0  | 1  | 1  | 1  | 1 | 1  | x+1 |
| 1  | 1  | 0  | 1  | 1 | 1  | y+1 |
| 0  | 0  | 1  | 1  | 1 | 0  | x-1 |
| 1  | 1  | 0  | 0  | 1 | 0  | y-1 |
| 0  | 0  | 0  | 0  | 1 | 0  | x+y |
| 0  | 1  | 0  | 0  | 1 | 1  | х-у |
| 0  | 0  | 0  | 1  | 1 | 1  | y-x |
| 0  | 0  | 0  | 0  | 0 | 0  | x&y |
| 0  | 1  | 0  | 1  | 0 | 1  | x y |

# แนวปฏิบัติ

- ใช้**ซิปเซต**ที่ได้ออกแบบไว้ก่อนหน้านี้
- ชิปที่ทำขึ้นใหม่ ใน Project-2
  - เกิดจากการประกอบกันของชิปใน Project-1
- •การสร้างซิปใหม่คือ copy ซิปเก่าแล้วเปลี่ยนชื่อ
  - เติมโค้ด HDL เพียงไม่กี่บรรทัด (เราตั้งใจให้เป็นเช่นนั้น)
- นักศึกษาสามารถผลิตชิป(เขียนโค้ด HDL) เพื่อช่วยงานให้ ตนเองทำงานได้ง่าย เราเรียกว่า 'helper chips'
- เพื่อให้การเรียนเป็นอย่างมีประสิทธิภาพ ควรใช้ชิปที่มาจาก การเรียนตามลำดับ แทนการเขียนชิปที่มีคุณสมบัติเกินจำเป็น